<template>
  <div class="container">
    <van-sku
      v-model="showBase"
      :sku="sku"
      :goods="goods"
      goods-id="1"
      :hide-stock="sku.hide_stock"
      :quota="quota"
      :quota-used="quotaUsed"
      :close-on-click-overlay="closeOnClickOverlay"
      :message-config="messageConfig"
      @buy-clicked="onBuyClicked"
      @add-cart="onAddCartClicked"
    />
  </div>
</template>

<script>
  import { Toast } from 'vant'
  export default {
    props: {
      value: Boolean,
      quota: {
        type: Number,
        default: 0
      },
      quotaUsed: {
        type: Number,
        default: 0
      },
      obj: Object
    },
    data () {
      return {
        showBase: false,
        closeOnClickOverlay: true,
        sku: {
          // 所有sku规格类目与其值的从属关系，比如商品有颜色和尺码两大类规格，颜色下面又有红色和蓝色两个规格值。
          // 可以理解为一个商品可以有多个规格类目，一个规格类目下可以有多个规格值。
          tree: [
            {
              k: '颜色', // skuKeyName：规格类目名称
              v: [
                {
                  id: '30349', // skuValueId：规格值 id
                  name: '红色', // skuValueName：规格值名称
                  imgUrl: 'https://img.yzcdn.cn/1.jpg' // 规格类目图片，只有第一个规格类目可以定义图片
                },
                {
                  id: '1215',
                  name: '蓝色',
                  imgUrl: 'https://img.yzcdn.cn/2.jpg'
                }
              ],
              k_s: 's1' // skuKeyStr：sku 组合列表（下方 list）中当前类目对应的 key 值，value 值会是从属于当前类目的一个规格值 id
            }
          ],
          // 所有 sku 的组合列表，比如红色、M 码为一个 sku 组合，红色、S 码为另一个组合
          list: [
            {
              id: 2259, // skuId，下单时后端需要
              price: 100, // 价格（单位分）
              s1: '1215', // 规格类目 k_s 为 s1 的对应规格值 id
              s2: '1193', // 规格类目 k_s 为 s2 的对应规格值 id
              s3: '0', // 最多包含3个规格值，为0表示不存在该规格
              stock_num: 110 // 当前 sku 组合对应的库存
            }
          ],
          price: '1.00', // 默认价格（单位元）
          stock_num: 227, // 商品总库存
          collection_id: 2261, // 无规格商品 skuId 取 collection_id，否则取所选 sku 组合对应的 id
          none_sku: false, // 是否无规格商品
          messages: [
            {
              // 商品留言
              datetime: '0', // 留言类型为 time 时，是否含日期。'1' 表示包含
              multiple: '0', // 留言类型为 text 时，是否多行文本。'1' 表示多行
              name: '留言', // 留言名称
              type: 'text', // 留言类型，可选: id_no（身份证）, text, tel, date, time, email
              required: '1' // 是否必填 '1' 表示必填
            }
          ],
          hide_stock: false // 是否隐藏剩余库存
        },
        goods: {
          // 商品标题
          title: '测试商品',
          // 默认商品 sku 缩略图
          picture: 'https://timgsa.baidu.com/timg?image&quality=80&size=b9999_10000&sec=1555581181&di=5cafac8a4550f6918e401f1c4b906363&imgtype=jpg&er=1&src=http%3A%2F%2Fk.zol-img.com.cn%2Fdcbbs%2F20031%2Fa20030774_s.jpg'
        },
        messageConfig: {
          // 图片上传回调，需要返回一个promise，promise正确执行的结果需要是一个图片url
          uploadImg: () => {
            return new Promise((resolve) => {
              setTimeout(() => resolve('https://img.yzcdn.cn/upload_files/2017/02/21/FjKTOxjVgnUuPmHJRdunvYky9OHP.jpg!100x100.jpg'), 1000);
            });
          },
          // 最大上传体积 (MB)
          uploadMaxSize: 3,
          // placehold配置
          placeholderMap: {
            text: 'xxx',
            tel: 'xxx'
          }
        }
      }
    },
    computed: {},
    created () {
    },
    mounted () {},
    methods: {
      onBuyClicked () {},
      async onAddCartClicked () {
        const arr = this.$store.state.car.arr
        let isHas = true
        if (arr.length === 0) {
          this.$store.commit('CAR_ADD', this.obj)
        } else {
          await arr.forEach(ele => {
            if (ele.name === this.obj.name) {
              isHas  = true
            } else {
              isHas = false
            }
          })
        }
        if (!isHas) {
          this.$store.commit('CAR_ADD', this.obj)
        } else {
          Toast('已经添加该商品！')
        }
      }
    },
    watch: {
      value (val) {
        this.showBase = val
      },
      showBase (val) {
        this.$emit('input', val)
      }
    }
  }
</script>
